package cn.iocoder.yudao.module.hs.service.picktaskmaterialdetail;

import cn.iocoder.yudao.framework.common.pojo.PageResult;
import cn.iocoder.yudao.module.hs.controller.admin.picktaskmaterialdetail.vo.PickTaskMaterialDetailPageReqVO;
import cn.iocoder.yudao.module.hs.controller.admin.picktaskmaterialdetail.vo.PickTaskMaterialDetailRespVO;
import cn.iocoder.yudao.module.hs.controller.admin.picktaskmaterialdetail.vo.PickTaskMaterialDetailSaveReqVO;
import cn.iocoder.yudao.module.hs.controller.admin.scan.vo.ScanInfoReqVO;
import cn.iocoder.yudao.module.hs.dal.dataobject.picktask.PickTaskDO;
import cn.iocoder.yudao.module.hs.dal.dataobject.picktaskmaterialdetail.PickTaskMaterialDetailDO;

import javax.validation.Valid;
import java.util.List;
import java.util.Set;

/**
 * 拣货物料明细 Service 接口
 *
 * @author 航盛
 */
public interface PickTaskMaterialDetailService {

    /**
     * 创建拣货物料明细
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createPickTaskMaterialDetail(@Valid PickTaskMaterialDetailSaveReqVO createReqVO);

    /**
     * 更新拣货物料明细
     *
     * @param updateReqVO 更新信息
     */
    void updatePickTaskMaterialDetail(@Valid PickTaskMaterialDetailSaveReqVO updateReqVO);

    /**
     * 删除拣货物料明细
     *
     * @param id 编号
     */
    void deletePickTaskMaterialDetail(Long id);

    /**
     * 获得拣货物料明细
     *
     * @param id 编号
     * @return 拣货物料明细
     */
    PickTaskMaterialDetailDO getPickTaskMaterialDetail(Long id);

    /**
     * 获得拣货物料明细分页
     *
     * @param pageReqVO 分页查询
     * @return 拣货物料明细分页
     */
    PageResult<PickTaskMaterialDetailDO> getPickTaskMaterialDetailPage(PickTaskMaterialDetailPageReqVO pageReqVO);

    /**
     * 根据code获得拣货物料明细列表
     *
     * @param code rfidCode/boxCode/materialCode
     * @return 拣货物料明细列表
     */
    List<PickTaskMaterialDetailDO> getPickTaskMaterialDetailByCode(String code);

    /**
     * 根据出库单id查询拣货物料明细列表
     *
     * @param shipOrderId 出库单id
     * @return 拣货物料明细列表
     */
    List<PickTaskMaterialDetailDO> getPickTaskMaterialDetailByShipOrderId(Long shipOrderId);

    /**
     * 获得拣货物料明细
     *
     * @param scanInfoReqVO
     * @return 拣货物料明细
     */
    List<PickTaskMaterialDetailRespVO> getPickTaskMaterialDetailList(ScanInfoReqVO scanInfoReqVO);

    /**
     * 批量插入扫码确认的拣货信息
     *
     * @param pickTaskDO
     * @return 拣货物料明细
     */
    void insertPickTaskMaterialDetail(PickTaskDO pickTaskDO, Long toWarehouseDeptId);

    /**
     * 通过产品码获得拣货物料明细
     *
     * @param materialCodeSet 物料编号Set
     * @return 拣货物料明细
     */
    List<PickTaskMaterialDetailDO> getPickTaskMaterialDetail(Long pickTaskId, Set<String> materialCodeSet);

    /**
     * 通过产品码获得拣货物料明细
     *
     * @param materialCode 物料编号
     * @return 拣货物料明细
     */
    PickTaskMaterialDetailDO getPickTaskMaterialDetail(String materialCode);

    /**
     * 通过出库单id获得拣货物料明细
     *
     * @param shipOrderId 出库单id
     * @return 拣货物料明细
     */
    List<PickTaskMaterialDetailDO> getPickTaskMaterialDetailList(Long shipOrderId);

    /**
     * 回退物料、物料箱、托盘的在库状态
     * @param shipOrderId
     */
    void rollbackPickTaskMaterialBoxTray(Long shipOrderId, Long warehouseId);
}